package JavaCode.lcof;

/**
 * @Author:fangjie
 * @Date:2020/4/28 12:59 上午
 */
public class 面试题56_I_数组中数字出现的次数 {
    public int[] singleNumbers(int[] nums) {
        int tag=0;
        for (int n:nums)tag^=n;

        int flag=tag&(-tag);
        int res=0;
        for (int n:nums){
            if((flag&n)!=0)res^=n;
        }
        return new int[]{res,res^tag};
    }
}
/*
一个整型数组 nums 里除两个数字之外，其他数字都出现了两次。请写程序找出这两个只出现一次的数字。要求时间复杂度是O(n)，空间复杂度是O(1)。

 

示例 1：

输入：nums = [4,1,4,6]
输出：[1,6] 或 [6,1]
示例 2：

输入：nums = [1,2,10,4,1,4,3,3]
输出：[2,10] 或 [10,2]
 

限制：

2 <= nums <= 10000

来源：力扣（LeetCode）
链接：https://leetcode-cn.com/problems/shu-zu-zhong-shu-zi-chu-xian-de-ci-shu-lcof
著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 */
